package org.jeecg.modules.wms.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
import org.jeecg.common.aspect.annotation.Dict;
import org.jeecgframework.poi.excel.annotation.Excel;
import org.springframework.format.annotation.DateTimeFormat;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;

/**
 * 入库单
 */
@Data
@TableName("wms_inbound_order")
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value = "wms_inbound_order对象", description = "入库单")
public class WmsInboundOrder implements Serializable {
    
    private static final long serialVersionUID = 1L;
    
    /**
     * 主键
     */
    @TableId(type = IdType.ASSIGN_ID)
    @ApiModelProperty(value = "主键")
    private String id;
    
    /**
     * 入库单号
     */
    @Excel(name = "入库单号", width = 15)
    @ApiModelProperty(value = "入库单号")
    private String inboundNo;
    
    /**
     * 业务类型
     */
    @Excel(name = "业务类型", width = 15)
    @ApiModelProperty(value = "业务类型")
    @Dict(dicCode = "inventory_business_type")
    private Integer businessType;
    
    /**
     * 业务单号
     */
    @Excel(name = "业务单号", width = 15)
    @ApiModelProperty(value = "业务单号")
    private String businessNo;
    
    /**
     * 批次号
     */
    @ApiModelProperty(value = "批次号")
    private String batchNo;
    
    /**
     * 供应商
     */
    @ApiModelProperty(value = "供应商")
    private String supplier;
    
    /**
     * 入库单状态：1-待入库 2-已入库 3-部分入库 4-已取消
     */
    @Excel(name = "入库单状态", width = 15)
    @ApiModelProperty(value = "入库单状态")
    @Dict(dicCode = "inbound_order_status")
    private Integer status;
    
    /**
     * 计划入库时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "计划入库时间", width = 20, format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "计划入库时间")
    private Date planInboundTime;
    
    /**
     * 实际入库时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "实际入库时间", width = 20, format = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "实际入库时间")
    private Date actualInboundTime;
    
    /**
     * 入库凭证
     */
    @ApiModelProperty(value = "入库凭证")
    private String inboundVoucher;
    
    /**
     * 生产订单ID（余料入库特有）
     */
    @ApiModelProperty(value = "生产订单ID")
    private String productionOrderId;
    
    /**
     * 是否余料
     */
    @ApiModelProperty(value = "是否余料")
    private Boolean isSurplus;
    
    /**
     * 物料图片
     */
    @ApiModelProperty(value = "物料图片")
    private String materialImages;
    
    /**
     * 总计划入库数量
     */
    @Excel(name = "总计划入库数量", width = 15)
    @ApiModelProperty(value = "总计划入库数量")
    private BigDecimal totalPlanQuantity;
    
    /**
     * 总实际入库数量
     */
    @Excel(name = "总实际入库数量", width = 15)
    @ApiModelProperty(value = "总实际入库数量")
    private BigDecimal totalActualQuantity;
    
    /**
     * 总成本
     */
    @Excel(name = "总成本", width = 15)
    @ApiModelProperty(value = "总成本")
    private BigDecimal totalCost;
    
    /**
     * 备注
     */
    @Excel(name = "备注", width = 15)
    @ApiModelProperty(value = "备注")
    private String remark;
    
    /**
     * 创建人
     */
    @ApiModelProperty(value = "创建人")
    private String createBy;
    
    /**
     * 创建时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "创建时间")
    private Date createTime;
    
    /**
     * 更新人
     */
    @ApiModelProperty(value = "更新人")
    private String updateBy;
    
    /**
     * 更新时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "更新时间")
    private Date updateTime;
    
    /**
     * 租户ID
     */
    @ApiModelProperty(value = "租户ID")
    private String tenantId;

    /**
     * 计划入库仓库名称（非数据库字段）
     */
    @TableField(exist = false)
    private String planWarehouseName;
    
    /**
     * 计划入库库位名称（非数据库字段）
     */
    @TableField(exist = false)
    private String planLocationName;
    
    /**
     * 实际入库仓库名称（非数据库字段）
     */
    @TableField(exist = false)
    private String actualWarehouseName;
    
    /**
     * 实际入库库位名称（非数据库字段）
     */
    @TableField(exist = false)
    private String actualLocationName;
    
    /**
     * 物料类型名称（非数据库字段）
     */
    @TableField(exist = false)
    private String materialTypeName;
    
    /**
     * 采购单号（采购入库时使用）
     */
    @ApiModelProperty(value = "采购单号")
    private String purchaseOrderNo;
    
    /**
     * 采购单ID（采购入库时使用）
     */
    @ApiModelProperty(value = "采购单ID")
    private String purchaseOrderId;

    /**
     * 操作人ID集合
     */
    @ApiModelProperty(value = "操作人ID集合")
    private String operatorIds;

    @ApiModelProperty(value = "操作人名称集合")
    private String operatorNames;
} 